<script lang="ts">
  import Tree from '$lib/components/shared-components/tree/tree.svelte';
  import { normalizeTreePath, type RecursiveObject } from '$lib/utils/tree-utils';

  interface Props {
    items: RecursiveObject;
    parent?: string;
    active?: string;
    icons: { default: string; active: string };
    getLink: (path: string) => string;
    getColor?: (path: string) => string | undefined;
  }

  let { items, parent = '', active = '', icons, getLink, getColor = () => undefined }: Props = $props();
</script>

<ul class="list-none ml-2">
  {#each Object.entries(items) as [path, tree]}
    {@const value = normalizeTreePath(`${parent}/${path}`)}
    {@const key = value + getColor(value)}
    {#key key}
      <li>
        <Tree {parent} value={path} {tree} {icons} {active} {getLink} {getColor} />
      </li>
    {/key}
  {/each}
</ul>
